import { Form } from '@/components/ui/form';
import { zodResolver } from '@hookform/resolvers/zod';
import { memo } from 'react';
import { useForm } from 'react-hook-form';
import { z } from 'zod';
import { initialDataOperationsValues } from '../../constant';
import { useFormValues } from '../../hooks/use-form-values';
import { useWatchFormChange } from '../../hooks/use-watch-form-change';
import { INextOperatorForm } from '../../interface';
import { FormWrapper } from '../components/form-wrapper';
import { DynamicVariables } from './dynamic-variables';

export const VariableAssignerSchema = {
  variables: z.array(
    z.object({
      variable: z.string().optional(),
      operator: z.string().optional(),
      parameter: z.string().or(z.number()).or(z.boolean()).optional(),
    }),
  ),
};

export const FormSchema = z.object(VariableAssignerSchema);

export type VariableAssignerFormSchemaType = z.infer<typeof FormSchema>;

// const outputList = buildOutputList(initialVariableAssignerValues.outputs);

function VariableAssignerForm({ node }: INextOperatorForm) {
  const defaultValues = useFormValues(initialDataOperationsValues, node);

  const form = useForm<VariableAssignerFormSchemaType>({
    defaultValues: defaultValues,
    mode: 'onChange',
    resolver: zodResolver(FormSchema),
  });

  useWatchFormChange(node?.id, form, true);

  return (
    <Form {...form}>
      <FormWrapper>
        <DynamicVariables name="variables" label="Variables"></DynamicVariables>
        {/* <Output list={outputList} isFormRequired></Output> */}
      </FormWrapper>
      {/* <DevTool control={form.control} placement="top-left" /> */}
      {/* set up the dev tool */}
    </Form>
  );
}

export default memo(VariableAssignerForm);
